草庐IT

javascript - 使用 Laravel 的 Ajax Post 错误 422

全部标签

ruby-on-rails - 使用 constantize 在 ruby​​ 中远程执行代码

当使用contantize时,我正试图解决ruby​​/rails中的远程代码执行漏洞。我知道能够向服务器提供任何类名可能存在潜在危险,但我想知道这本身是否危险。例如,如果RailsController代码看起来像这样(即在实例化对象上执行硬编码方法):klass=params[:class].classify.constantizeklass.do_something_with_id(params[:id])ifklass.respond_to?('do_something_with_id')此代码易受攻击吗?还是只能结合指定要在类上调用的方法? 最佳答案

ruby - 在方法定义中使用 $1、$2 等全局变量

给定以下两段代码:defhello(z)"hello".gsub(/(o)/,&z)endz=proc{|m|p$1}hello(z)#prints:nildefhelloz=proc{|m|p$1}"hello".gsub(/(o)/,&z)endhello#prints:"o"为什么这两段代码的输出不同?有没有一种方法可以从方法定义外部将block传递给gsub,以便变量$1、$2将在相同的情况下进行评估好像block是在方法定义中给出的? 最佳答案 Whytheoutputisdifferent?ruby中的proc具有词法作

ruby - 如何使用 Ruby Duck 打字

我正在学习Ruby,我遇到了一个关于打字的主要概念问题。请允许我详细说明为什么我不理解范式。假设我像您在Ruby中一样为简洁的代码进行方法链接。我必须准确地知道链中每个方法调用的返回类型是什么,否则我无法知道下一个链接上有哪些方法可用。难道我每次都要检查方法文档吗??我遇到了这个不断运行的教程练习。似乎我陷入了引用、推断、运行、失败、修复、重复以使代码运行的过程,而不是准确地知道我在编码过程中使用的是什么。这与Ruby的直观性promise背道而驰。假设我正在使用第三方库,我再次需要知道允许哪些类型传递参数,否则我会失败。我可以查看代码,但可能有也可能没有任何关于该方法期望的类型的注释

ruby-on-rails - Rails 4 路由错误 : No Route Matches [POST]

我在学习Rails4时正在做一个小练习,但在尝试更新对象时遇到路由错误。我不断收到错误消息:没有路由匹配[POST]"/movies/1/edit"但看不到我的代码哪里不正确:我的电影_controller.rbclassMoviesController"Yourmoviewassaved!"elserender"new"endenddefedit@movie=Movie.find(params[:id])enddefupdate@movie=Movie.find(params[:id])if@movie.update_attributes(params[:movie])redirec

ruby - (Watir webdriver) 在 OSX 10.9 中使用多显示器时如何将浏览器移动到另一个屏幕

我知道有一个名为browser.window.move_to(0,0)的函数可以将浏览器移动到不同的位置,但OSX10.9对它来说是全新的。有什么方法可以将浏览器移动到另一个桌面吗?例如。在“桌面2”中触发命令的控制台,但我希望浏览器出现在“桌面1”中。非常感谢! 最佳答案 哈,在我尝试这个之前我正要说这可能是不可能的:browser.window.move_to(-1200,0)我的第二台显示器位于主屏幕的左侧。有效。好问题。您需要花点时间才能正确使用它,但watir似乎能够使用整个显示器Canvas。例如,如果您的显示器位于主屏

Ruby 错误地解析了两位数的年份

Ruby正确解析第一个日期,但第二个日期不正确。使用ruby​​1.9.3和2.1.2测试。知道如何让它始终如一地工作吗?(我们将出生日期设为2位数年份)Date.strptime("10/11/89","%d/%m/%y")=>Fri,10Nov1989Date.strptime("15/10/63","%d/%m/%y")=>Mon,15Oct2063 最佳答案 strptime方法将文本“63”解析为2063年,而不是您想要的1963年。这是因为该方法使用POSIXstandard来决定世纪。.chronicgem也有类似的问

ruby-on-rails - Rails 使用 Symbol 与 String 作为 params hash 中的键

如果我们使用字符串作为哈希键,Ruby需要计算字符串并查看它的内容(并计算其上的哈希函数)并将结果与​​已存储的键的(哈希)值进行比较在哈希中。如果我们使用一个符号作为散列键,则暗示它是不可变的,因此Ruby基本上可以将对象ID的(散列函数)与键的(散列)对象ID进行比较已经存储在哈希中。(快得多)。但问题在于Railsparams,它是HashWithIndifferentAccess的实例,如果我们编写params[:some_key]它会转换:som​​e_key到'some_key'然后它会尝试在参数散列中查找键。line159defconvert_key(key)key.ki

ruby-on-rails - Curl::Error::Partial File Error: 传输部分文件错误

我正在尝试在Rails控制台中执行以下代码:ce=Curl::Easy.new("http://www.homestolove.com.au/bathroom-profile-fresh-approach-2391")ce.verbose=truece.perform但我收到以下错误。谁能建议如何解决这个问题?看起来这个url返回响应的速度很慢。在文件传输完成之前,我们可以做些什么来阻止连接终止吗?*Addinghandle:conn:0x95f3210*Addinghandle:send:0*Addinghandle:recv:0*Curl_addHandleToPipeline:l

ruby-on-rails - 在 Rails 上验证有限状态机(使用 AASM)

我正在使用AASMbyRubyist为AR对象构建4步向导。根据对象的状态,需要进行不同的验证。根据对象在特定转换时的状态来验证对象的最明智方法是什么? 最佳答案 使用:if选项和with_options将它们捆绑在一起。classPostproc{|r|r.signup_step>2}do|o|o.validates_presence_of:titleo.validates_presence_of:yeahendend显然,您应该在if-proc中具体写什么取决于您的实现。 关于rub

ruby - 如何在 Ruby 应用程序中找到未使用的方法?

我有一个包含很多类/模块的Ruby应用程序,其中一些没有被使用。有没有一种简单的方法可以找出是哪一个?我想做一个配置文件,然后使用它的输出。还有其他想法吗? 最佳答案 像rcov这样的覆盖工具可能会有所帮助。https://github.com/relevance/rcov当您发现测试未涵盖的方法时,您应该为它们编写测试或查明它们是否被使用。删除未使用的方法是重构的一部分,如果您有太多的类可能会产生代码异味,也需要重构。 关于ruby-如何在Ruby应用程序中找到未使用的方法?,我们在S